package com.gali.mall.model.dao;

import com.gali.mall.model.pojo.Product;
import com.gali.mall.model.query.ProductListQuery;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.springframework.stereotype.Repository;

import java.util.List;

@Mapper
@Repository
public interface ProductMapper {
    int deleteByPrimaryKey(Integer id);

    int insert(Product record);

    int insertSelective(Product record);

    Product selectByPrimaryKey(Integer id);

    int updateByPrimaryKeySelective(Product record);

    int updateByPrimaryKey(Product record);

    /**
     * 查询商品是否重名
     * @param name
     * @return
     */
    Product checkInName(String name);

    /**
     * 查询全部商品
     * @return
     */
    List<Product> selectAll();

    /**
     * 模糊查询商品
     * @param name
     * @return
     */
    List<Product> selectFromName(String name);

    /**
     * 批量删除
     * @param ids
     * @param status
     * @return
     */
    int updateBrachStatus(Integer[] ids,Integer status);

    /**
     *商品列表（模糊查询）
     * @param query
     * @return
     */
    List<Product> selectList(@Param("query") ProductListQuery query);
}